<template>
  <div class="sex">
    <div class="title">
      <p>男女比例</p>
      <img src="../../images/dataScreen-title.png" alt="" />
    </div>
    <div class="gender">
      <div class="man">
        <img src="../../images/man.png" alt="" />
      </div>
      <div class="woman">
        <img src="../../images/woman.png" alt="" />
      </div>
    </div>

    <div class="rate">
      <p>男士58</p>
      <p>女士38</p>
    </div>

    <div class="charts" ref="charts"></div>
  </div>
</template>

<script setup lang="ts">
  import * as echarts from 'echarts'
  import { onMounted, ref } from 'vue'

  const charts = ref()
  onMounted(() => {
    let myCharts = echarts.init(charts.value)
    myCharts.setOption({
      //组件标题
      title: {
        text: '男女比例', //主标题
        textStyle: {
          //主标题颜色
          color: 'skyblue',
        },
        left: '40%',
      },
      //x|y
      xAxis: {
        show: false,
        min: 0,
        max: 100,
      },
      yAxis: {
        show: false,
        type: 'category',
      },
      series: [
        {
          type: 'bar',
          data: [58],
          barWidth: 20,
          z: 100,
          itemStyle: {
            color: 'skyblue',
            borderRadius: 20,
          },
        },
        {
          type: 'bar',
          data: [100],
          barWidth: 20,
          //调整女士柱条位置
          barGap: '-100%',
          itemStyle: {
            color: 'pink',
            borderRadius: 20,
          },
        },
      ],
      grid: {
        left: 0,
        top: 0,
        right: 0,
        bottom: 0,
      },
    })
  })
</script>

<style lang="scss" scoped>
  .sex {
    width: 100%;
    height: 100%;
    background: url(../../images/dataScreen-main-cb.png) no-repeat;
    background-size: 100% 100%;
    margin: 20px 0;
    .title {
      margin-left: 20px;
      p {
        color: #fff;
        font-size: 20px;
      }
    }
    .gender {
      display: flex;
      justify-content: center;
      .man {
        margin: 20px;
        width: 111px;
        height: 115px;
        background: url(../../images/man-bg.png) no-repeat;
        display: flex;
        justify-content: center;
        align-items: center;
      }
      .woman {
        margin: 20px;
        width: 111px;
        height: 115px;
        background: url(../../images/woman-bg.png) no-repeat;
        display: flex;
        justify-content: center;
        align-items: center;
      }
    }
    .rate {
      width: 53%;
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      color: #fff;
    }
    .charts {
      height: 100px;
      width: 53%;
      margin: 0 auto;
    }
  }
</style>
